草庐IT

Python Django 模板 : Iterate Through List

全部标签

c++ - 我可以使用动态数组作为 C++ 模板类型名吗?

至于下面的代码:templatecl_intenqueueFillBuffer(constBuffer&buffer,PatternTypepattern,::size_toffset,::size_tsize,constVECTOR_CLASS*events=NULL,Event*event=NULL)const{cl_eventtmp;cl_interr=detail::errHandler(::clEnqueueFillBuffer(object_,buffer(),static_cast(&pattern),sizeof(PatternType),offset,size,(ev

通用模板 ostream << 运算符的 C++ 不明确重载

这个问题紧接我之前的问题:Genericoperator我想在哪里实现一个通用的适用于拥有to_str()的任何类的运算符方法。我已经成功地检查了一个类是否实现了to_str()方法与用途std::cout感谢这个answer.但是,我在编写模板时遇到困难ostream运营商制作std::cout有效。以下测试代码:#include#include#includetemplateusingvoid_t=void;templatestructhas_to_string:std::false_type{};templatestructhas_to_string().to_str())>>:

c++ - 模板仿函数与函数

我一直在查看一些Boost源代码并注意到它们通过使用仿函数而不是普通函数来实现模板化函数?这是有原因的吗?例如:templatestructfunctor{Baroperator()(constFoo&foo){returnfoo.as_bar();}};相对于:templateBarfunc(constFoo&foo){returnfoo.as_bar();}我能想到的唯一优点是它允许类继承函数? 最佳答案 主要有两个原因:首先,正如pythonic隐喻所指出的,偏特化只对类有效,对函数无效。请注意,函数通常可以使用重载来克服这个

c++ - 防止模板化成员函数中某些参数的隐式转换

目前我有一个这样定义的成员函数:templateboolupdateParameter(conststd::string&name,constT&data);指针重载。templateboolupdateParameter(conststd::string&name,T*data);我希望能够像这样使用这个函数:inttest=20;updateParameter("name",0);updateParameter("Referencedparameter",&test);这样我就可以拥有一个参数对象,该对象要么拥有它所代表的数据,要么指向用户拥有的成员。现在我遇到的问题是当前设置MS

c++ - 为什么 SFINAE 需要 'Enable' 类模板参数?

(本题与C++11/C++14无关:示例使用C++03编译)enable_bool有成员(member)::type仅当T是booltemplatestructenable_bool{};templatestructenable_bool{typedefbooltype;};在下一个片段中,部分特化是正确的(参见gcc.godbolt.org)templatestructFoo{staticintbar(){return0;}};templatestructFoo::type>{staticintbar(){return1;}};intmain(){returnFoo::bar();}

c++ - 为什么模板化的右值引用接受左值?

我看到了类似的用法#include#includeusingnamespacestd;templatevoidFoo(FN&&Fn){Fn();}voidb(){coutd=c;Foo(d);return0;}我相当确定“c”是左值,但我可以相信存在一些lambda类型推导恶作剧。但我几乎100%肯定,d是一个左值。如果函数接受一个右值,但d是一个左值,为什么模板化的东西可以工作?此外,为什么一个人会这样写Foo的签名而不是仅仅templatevoidFoo(FNFn) 最佳答案 T&&的扣除规则很棘手。它们的设计目的是推导T&&“

c++ - 使用模板模板参数打破模板循环依赖

如果我的理解是正确的,下面是模板类之间的经典循环依赖:templatestructA{MyB*b_;};templatestructB{MyA*a_;};如果我们要实例化A与B和B与A,那么我们不能从任何一个开始,因为我们必须写:A>>(无限)。我认为模板模板参数提供了一种解决方案。以下代码编译(使用gcc版本4.8.2):templatestructA{MyB*b_;};templateclassMyA>structB{MyA*a_;};intmain(){usingMyB=B;usingMyA=A;MyAa;MyBb;a.b_=&b;b.a_=&a;return0;}我是否遗漏了问

c++ - 具有单个参数模板的成员函数包装器?

我做了一个模板函数,它接受一个成员函数作为参数。但是,由于类必须先声明才能用作成员函数参数的一部分,因此我必须将其作为一个单独的参数:templatefunctionmethodWrap(){}这意味着当显式实例化模板时(我希望这些包装器在编译时生成,而不是将成员指针作为参数传递)我在使用它时必须输入两次:functionsomeFunc=wrapMethod();为什么我不能写这样的东西:templatefunctionmethodWrap(){}并让它捕获C的类型及其成员函数指针,而无需键入两次SomeClass?或者为什么我不能将它包装在一个将C声明为“自由变量”然后具有执行推导

c++ - std::string & 作为 gcc 5 中的模板参数和 abi_tag

考虑以下代码(test1.cpp):#includeexternstd::stringtest_string;templateclasstest{public:staticvoidbar(){}};std::stringtest_string("teststring");voidfoo(){test::bar();}现在让我们交换最后两行代码(test2.cpp)的顺序:#includeexternstd::stringtest_string;templateclasstest{public:staticvoidbar(){}};voidfoo(){test::bar();}std::

内部类中的 C++ 模板运算符重载

如何为类模板的内部类重载operator+?我已经搜索了几个小时,但找不到答案。这是一个不起作用的最小示例:#includeusingnamespacestd;templatestructA{structB{Tm_t;B(Tt):m_t(t){}};};templatetypenameA::Boperator+(typenameA::Blhs,intn){lhs.m_t+=n;returnlhs;}intmain(intargc,char**argv){Aa;A::Bb(17.2);autoc=b+5;cout如果我这样编译,我会得到error:nomatchfor‘operator+